# PATENT ABSTRACTS OF JAPAN

(11)Publication number:

07-262233

(43)Date of publication of application: 13.10.1995

(51)Int.CI.

G06F 17/50

(21)Application number: 06-047480

(71)Applicant: FUJITSU LTD

**FUJITSU VLSI LTD** 

(22)Date of filing:

17.03.1994

(72)Inventor: UECHI MASAHITO

### (54) METHOD AND DEVICE FOR DECIDING FORM OF ELEMENT IN ANALOG LSI

(57)Abstract:

PURPOSE: To automatically decide the form of an element satisfying an analog restriction.

CONSTITUTION: In the ascertaining processing 31 of the same form element group as against plural kinds of elements mentioned by the element numbers of a net list, an approximate arrangement condition which is previously set so that they are set to be the same forms is inputted. It is judged whether the plural elements applied to the approximate arrangement condition exists on the net list or not. When the plural elements applied to the approximate arrangement condition exist, the element numbers are set to be one group, and respective groups are stored as intermediate data. In the deciding processing 33 of the element form, element form designation where a basic form designated for constituting the element is previously defined as against the element number is inputted, and it is judged whether the element numbers in the respective groups as intermediate data are applied to the element numbers designated for inputted element form designation or not. When they are applied, the plural basic forms are used for parameters showing the characteristics of the elements so as to decide the forms of the elements.



#### **LEGAL STATUS**

[Date of request for examination]

[Date of sending the examiner's decision of rejection]

[Kind of final disposal of application other than the examiner's decision of rejection or application converted registration]

[Date of final disposal for application]

[Patent number]

[Date of registration]

[Number of appeal against examiner's decision of rejection]

[Date of requesting appeal against examiner's decision of rejection]

[Date of extinction of right]

Copyright (C); 1998,2000 Japan Patent Office

(19)日本国特許庁 (JP)

# (12) 公開特許公報(A)

(11)特許出願公開番号

# 特開平7-262233

(43)公開日 平成7年(1995)10月13日

(51) Int.Cl.<sup>6</sup>

識別記号

庁内整理番号

FΙ

技術表示箇所

G06F 17/50

7623-5L

G06F 15/60

370 K

## 審査請求 未請求 請求項の数6 〇L (全 10 頁)

(21)出願番号

(22)出願日

特願平6-47480

平成6年(1994)3月17日

(71)出願人 000005223

富士通株式会社

国上进怀八五世

神奈川県川崎市中原区上小田中1015番地

(71)出願人 000237617

富士通ヴィエルエスアイ株式会社

愛知県春日井市高蔵寺町2丁目1844番2

(72)発明者 植地 將人

愛知県春日井市高蔵寺町二丁目1844番2

富士通ヴィエルエスアイ株式会社内

(74)代理人 弁理士 恩田 博宜

# (54) 【発明の名称】 アナログLSIにおける素子の形状決定方法及びその形状決定装置

#### (57)【要約】

【目的】アナログの制約を満足した素子の形状を自動的 に決定する。

【構成】ネットリストの素子番号により記述された複数種類の素子に対して、同一形状素子群の見極め処理31にて、予め同一形状とするために設定された近接配置条件を入力し、近接配置条件に該当する複数の素子がネットリスト上にあるかどうかを判断する。そして、近接配置条件に該当する複数の素子がある場合にはこれらの素子番号を1つのグループとし各グループを中間データとして記憶する。素子形状の決定処理33において、予め素子番号に対してその素子を構成するために指定された基本形状が定義された素子形状指定を入力し、前記中間データとして記憶された素子形状指定を入力し、前記中間データとして記憶された素子形状指定を入力し、前記中間データとして記憶された素子の構成するために指定された素子番号に該当するか否かを判断し、該当する場合にはその基本形状をその素子の特性を示すパラメータに対応して複数使用して素子の形状を決定する。

### 一実施例の形状決定装置の処理フロー図



#### 【特許請求の範囲】

【請求項1】 予め設定されたネットリストに素子番号 により記述された複数種類の素子の形状を決定するアナ ログLSIにおける素子の形状決定方法であって、

予め同一形状とするために設定された近接配置条件を入 力し、該近接配置条件に該当する複数の素子がネットリ スト上にあるかどうかを判断し、複数の素子がある場合 にはこれらの素子番号を1つのグループとし各グループ を中間データとして記憶し、

れた基本形状が定義された素子形状指定を入力し、

該素子形状指定にある素子番号が前記中間データに格納 された各グループ内の素子番号にあるか否かを判断し、 素子番号がある場合にはグループ内の各素子の特性を示 すパラメータを基本形状の特性を示すパラメータでそれ ぞれを割る除算を行い、

その除算の結果、商が整数の場合にはその商を各素子を 構成する基本形状の個数としてその素子の形状を決定す るようにしたアナログLSIにおける素子の形状決定方

【請水項2】 請木項1に記載のアナログL S 1 におけ る素子の形状決定方法において、

前記除算の結果、割り切れない場合であって該素子が抵 抗の場合には、割った結果の余りを予め設定された所定 の数で割る除算を行い、

除算の結果の商と基本形状の抵抗値とで抵抗を形成した 場合の抵抗値が素子の特性を示すパラメータである抵抗 値に対して予め設定された誤差範囲の抵抗値となるまで 除算を行い。

その誤差範囲の抵抗値となる除算の結果の商を各素子を 30 構成する基本形状の個数としてその素子の形状を決定す るようにしたアナログLSIにおける素子の形状決定方 法。

【請求項3】 請求項1尺は2に記載のアナログしS1 における素子の形状決定方法において、

前記中間データとして記憶された各グループ内の素子番 号が素子形状指定に指定された素子番号にない場合であ って、

該素子番号の素子がトランジスタ又は容量の場合は、同 一形状とする各素子の特性を示すバラメータの最大公約 40 数を求め、その最大公約数の素子を基準とし、

各素子の特性に対応して使用する基準となる素子の個数 を求め、基準となる素子とその基準となる素子の個数と により該素子の形状を決定し、

該素子が抵抗の場合は、そのうちの1つの抵抗値のサイ ズを基準サイズとし、その基準サイズにより各抵抗を自 動生成した場合の総面積を計算し

その総面積が最も小さくなるときの基準サイズで各素子 を形成する個数を計算し、

基準サイズと各素子を形成する個数とにより該素子の形 50

状を決定するようにしたアナログLSIにおける素子の 形状决定方法。

【請求項4】 予め設定されたネットリストに素子番号 により記述された複数種類の素子の形状を決定するアナ ログLSIにおける構成する素子の形状決定装置であっ

予め同一形状とするために設定された近接配置条件を入 力し、該近接配置条件に該当する複数の素子がネットリ スト上にあるかどうかを判断し、複数の素子がある場合 予め素子番号に対してその素子を構成するために指定さ 10 にはこれらの素子番号を1つのグループとし各グループ を中間データとして記憶する同一形状素子群の見極め手 段(31)と、

> 予め素子番号に対してその素子を構成するために指定さ れた基本形状が定義された素子形状指定を入力し、該素 子形状指定にある素子番号が前記中間テータに格納され た各ゼループ内の素子番号にあるが否かを判断し、素子 番号かある場合にはグループ内の各素子の特性を示すバ ラメータを基本形状の特性を示すパラメータで割る除算 を行い、その除算の結果、商が整数の場合にはその商を 各素子を構成する基本形状の個数としてその素子の形状 20 を決定する素子形状の決定手段(33)とを備えたアナ ログしSIにおける素子の形状決定装置。

【請求項5】 請求項4に記載のアナログLSIにおけ る素子の形状決定装置において、

前記素子形状の決定手段(33)は、

前記除算の結果が割り切れない場合であって該素子が抵 抗の場合には、割った結果の余りを予め設定された所定 の数で割る除算を行い、除算の結果の商と基本形状の抵 抗値とで抵抗を形成した場合の抵抗値が素子の特性を示 すバラメータである抵抗値に対して予め設定された誤差 範囲の抵抗値となるまで除算を行い。その誤差範囲の抵 抗値となる除算の結果の商を各素子を構成する基本形状 の個数としてその素子の形状を決定するようにしたアナ ログしSIにおける素子の形状決定装置。

【請求項6】 請求項4又は5に記載のアナログLSI における素子の形状決定装置において、

前記中間データとして記憶された各グループ内の素子番 号が素子形状指定に指定された素子番号に該当しない場 台であって、

該素子番号の素子がトランジスタ又は容量の場合は、同 一形状とする各素子の特性を示すパラメータの最大公約 数を求め、その最大公約数の素子を基準とし、各素子の 特性に対応して使用する基準となる素子の個数を求め、 基準となる素子とその基準となる素子の個数とにより該 素子の形状を决定し、

該素子が抵抗の場合は、そのうちの1つの抵抗値のサイ ズを基準サイズとし、その基準サイズにより各抵抗を自 動生成した場合の総面積を計算し、その総面積が最も小 さしなるときの基準サイズで各素子を形成する個数を計 算し 基準サイズと各素子を形成する個数とにより誇素

子の形状を決定する素子形状の最終決定手段(34)を 備えたアナログLSIにおける素子の形状決定装置。

#### 【発明の詳細な説明】

#### [0001]

【産業上の利用分野】本発明はアナログLSIにおける 素子の形状決定方法及びその形状決定装置に係り、詳し くはアナログLSIにおけるレイアウトの制約を満足 し、高集積化が可能な素子の自動形状决定に関するもの である。

【0002】近年、バイポーラ・アナログ【Cにおいて 10 は 大規模化・高集積化が進められる一方で、その開発 期間の短縮が要求されている。そのため、レイアウトに おいても素子の形状決定の自動化を図り配置処理時間を 短縮することが望まれている。

#### [0003]

【従来の技術】従来、バイポーラ・アナログIC(Inte grated Circuit)においては、大規模化・高集積化が進 められている。そのため、アナログICの回路設計にお いてはCAD (Computer Aided Design ) 装置が用いら れ その設計時間の短縮が図られている。また 設計さ れたアナログ!○が正常に動作するかを検証するための 検証プログラム (回路シミュレータ) が用いられ、計算 機による動作の検証が行われて検証時間が短縮されてい る。

#### [0004]

【発明が解決しようとする課題】ところで、アナログ1 Cのレイアウトには、そのレイアウトに多くの制約があ る。その制約は、例えばカレントミラーを構成する一针 のトランジスタは隣接して配置する必要がある。また、 例えば1つのトランシスタに対してそのトランジスタに 30 流れる10倍の電流を流すトランジスタを設計する場 合、単純にそのトランシスタの形状を10倍するだけて は所望の電流が得られない。そのため、同一形状のトラ ンジスタを主じ個隣接して形成して所望の電流を得る必 要がある。これらの制約によりマクロを構成する素子の レイアウト及びマクロのレイアウト時における素子の形 状決定は熟練した設計者自身により行われている。

【0005】一方、レイアウトを自動化したものもある が、そのレイアウトのための素子の形状は使用する素子 毎に予め設定しておかなければならないので、その設定 40 のために多くの時間がかかり、アナログICの開発期間 を短縮てきないという問題があった。

【0006】本発明は上記問題点を解決するためになさ れたものであって、その目的はアナログの制約を満足し た素子の形状を自動的に決定することのできるアナログ LSIにおける素子の形状決定方法及び形状決定装置を 提供することにある。

## [0007]

【課題を解決するための手段】本発明は上記目的を達成 するため「予め設定されたネットリストに素子番号によ」50「指定を入力し」前記中間データとして記憶された各グル

り記述された複数種類の素子の形状を決定するアナログ LSIにおける素子の形状決定方法であって。予め同一 形状とするために設定された近接配置条件を入力し、該 近接配置条件に該当する複数の素子がネットリスト上に あるかどうかを判断し、複数の素子がある場合にはこれ らの素子番号を1つのグループとし各グループを中間デ ータとして記憶し、子め素子番号に対してその素子を構 成するために指定された基本形状が定義された素子形状 指定を入力し、該素子形状指定にある素子番号が前記中 間データに格納された各グループ内の素子番号にあるか 否かを判断し、素子番号がある場合にはグループ内の各 素子の特性を示すパラメータを基本形状の特性を示すパ ラメータで割る除算を行い、その除算の結果、商が整数 の場合にはその商を各素子を構成する基本形状の個数と してその素子の形状を決定するようにした。

4

【0008】また、除算の結果。割り切れない場合であ って素子が抵抗の場合には 割った結果の余りを予め設 定された所定の数で割る除算を行い、除算の結果の商と 基本形状の抵抗値とで抵抗を形成した場合の抵抗値が素 子の特性を示すバラメータである抵抗値に対して予め設 定された誤差範囲の抵抗値となるまで除算を行い、その 誤差範囲の抵抗値となる除算の結果の商を各素子を構成 する基本形状の個数としてその素子の形状を決定するよ うにした、

【0009】更に、中間データとして記憶された各グル ープ内の素子番号が素子形状指定に指定された素子番号 にない場合であって、素子番号の素子がトランジスタ又 は容量の場合は、同一形状とする各素子の特性を示すハ ラメータの最大公約数を求め、その最大公約数の素子を 基準とし、各素子の特性に対応して使用する基準となる 素子の個数を求め、基準となる素子とその基準となる素 子の個数とにより該素子の形状を決定し、素子が抵抗の 場合は、そのうちの1つの抵抗値のサイスを基準サイズ とし、その基準サイスにより各抵抗を自動生成した場合 の総面積を計算し、その総面積が最も小さくなるときの 基準サイズで各素子を形成する個数を計算し、基準サイ スと各素子を形成する個数とにより該素子の形状を決定 するようにした。

#### [0010]

【作用】従って、本発明によれば、予め設定されたネッ トリストに素子番号により記述された複数種類の素子に 対して 予め同一形状とするために設定された近接配置 条件を入力し、該近接配置条件に該当する複数の素子が ネットリスト上にあるかどうかが判断される。そして近 接配置条件に該当する複数の素子かある場合にはこれら の素子番号を1つのグループとし各グループを中間デー 々として記憶する。

【0011】更に、予め素子番号に対してその素子を構 成するために指定された基本形状が定義された素子形状 一プ内の素子番号に入力した素子形状指定に指定された素子番号があるか否かか判断される。そして、素子番号がある場合にはグループ内の各素子の特性を示すパラメータを基本形状の特性を示すパラメータで割る除算を行い、その除算の結果。商が整数の場合にはその商を各素子を構成する基本形状の個数としてその素子の形状が決定される。

【0012】一方、除算の結果、商が整数でない場合であって該素子が抵抗の場合には、割った結果の余りを予め設定された所定の数で割る除算を行う。そして、除算 10の結果の商と基本形状の抵抗値とで抵抗を形成した場合の抵抗値が素子の特性を示すパラメータである抵抗値に対して予め設定された誤差範囲の抵抗値となるまて除算が繰り返される。そして、その誤差範囲の抵抗値となる除算の結果の商を各素子を構成する基本形状の個数としてその素子の形状が決定される。

【0013】また、中間データとして記憶された各グループ内の素子番号が素子形状指定に指定された素子番号にない場合であって、素子番号の素子がトランジスタ又は容量の場合は、同一形状とする各素子の特性を示す。20ラメータの最大会約数が末められる。そして、その最大公約数の素子を基準とし、各素子の特性に対応して使用する基準となる素子の個数とにより該素子の形状が決定される。一方、素子が抵抗の場合は、そのうちの1つの抵抗値のサイズを基準サイズとし、その基準サイズにより各抵抗を自動生成した場合の総面積が計算される。そして、その総面積が最も小さくなるときの基準サイズで各素子を形成する個数を計算され、その基準サイズと各素子を形成する個数とにより該素子の形状が決定される。

#### [0014]

【実施例】以下 本発明を具体化した一実施例を図1~図10に従って説明する。図2は本発明を適用したレイアウト装置のシステム構成を示す模式図である。形状決定装置1はCAD(Computer Aided Design)装置からなり、中央処理装置(以下、CPUという)2、メモリ3、磁気ディスク装置4、CRT等のディスプレイ5、キーボード(マウス等を含む)6、磁気テープ装置7を備えている。

【0015】CPU2はメモリ3に記憶された所定のプログラムデータに基づいて動作するようになっている。メモリ3にはCPU2が実行する前記プログラムデータとその実行に必要は各種データが予め記憶されるとともに、当該プログラムデータに基づくCPU2の処理結果等が一時格納されるようになっている。

【0016】メモリ3には、図1に示す複数のファイル 11~21が格納されている。ファイル11には、アナログ1Cの素子及びその素子間の接続(ネットリスト) が格納されている。ネットリストは図示しない回路設計 50

のためのCAD装置等により予め設計された回路図から 生成されている。また、ネットリストはその動作に応じ た複数の回路ブロックから構成され、各回路ブロックは 複数の素子又は複数の素子からなるマクロにより構成さ れている。そして、ネットリストには各素子を示す素子 番号と、その素子の特性を示すパラメータ(例えばトラ ンジスタではそのトランジスタに流す電流等)か同時に 記述されている。

【0017】ファイル12には、アナログ1Cのレイアウトの制約である近接配置、同一形状にする素子を決定する近接配置条件が格納されている。ファイル13には、形状決定するための素子が一旦格納されるための中間データが格納されている。

【0018】ファイル14には、予め近接配置、同一形 状にする素子を指定するために複数の素子番号が定義さ れた近接配置指定が格納されている。ファイル15に は、予め複数の素子に対してその素子を構成するための 基準となる基本形状が定義された素子形状指定が格納さ れている。ファイル16には、抵抗の形状を決定する際 において、複数の抵抗からその抵抗値を形成する場合に その抵抗を構成する個数を算出する時、元の抵抗値と複 数の抵抗により構成する抵抗値との誤差を定義した許容 誤差が格納されている。ファイル17には、ファイル1 3の中間データに格納された素子の形状と対応するセル 名を定義した素子対応指定が格納されている。また、フ ァイル 1 7 には、抵抗、容量(コンデンサ)の自動生成 を指定する定義が格納されている。ファイル18には、 素子を自動生成する時の条件を定義した素子自動生成パ ラメータが格納されている。ファイル19には、抵抗の 形状を自動生成する時の抵抗幅が格納されている。ファ イル20には、ファイル11に格納されたネットリスト に存在する全素子の形状及び配置個数が決定された素子 形状情報が格納される。ファイル21には素子の形状を 決定することができなかった素子番号がエラー素子とし て格納されるようになっている。

【0019】各ファイル11~19は磁気ディスク装置4に格納され、その磁気ディスク装置4からメモリ3に子め読み込まれて格納されている。一方、ファイル20はメモリ3に一旦格納され、処理終了とともに磁気ディスク装置4に格納されるようになっている。

【0020】CPU2は、キーボード6の操作により形状決定処理が起動されると、メモリ3に記憶されたプログラムデータに基づいて図1に示す素子の形状決定処理を実行する。即ち、CPU2はプログラムデータに基づいて同一形状素子群の見極め処理31、同一形状素子群の見極め追加処理32、素子形状の決定処理33及び素子形状の最終決定処理34の各構成を実行するようになっている。

【0021】同一形状素子群の見極め手段としての同一 形状素子群の見極め処理31において、CPU2はファ

イル11に格納されたネットリストを読み出す。また、 CPU2はファイル L2に格納された近接配置条件を読 み出す。そして、CPU2は読み出したネットリストに 記述されたネット (素子間の接続) の素子のうち、読み 出した近接配置条件に該当する素子をネットリストから 検索する。即ち、近接に配置する必要のある素子は同一 の電気的特性が必要であり、同一形状で形成する必要が ある。そのため、ネットリストに該当する素子が存在す る場合。CPU2はネットリストに記述されたその素子 を示す素子番号とファイル12に格納された素子のサイ 10 ズを中間データとしてファイル13に格納する。

【0022】この近接配置条件は、例えば図3に示すよ うに予め定義されている。例えば、エミッタ結合のよう に2つのトランジスタのエミッタ端子が互いに接続され ている場合がある。この両トランジスタの接続は、定義 『NPN1:E,NPN2:E 」の 『NPNトランジスタのエミッタ端 子同士が接続されている場合は近接配置を行う」に該当 する。従って、CPU2はこの近接配置条件に該当する 両トランジスタを1つのグループとし、その素子名を示 す素子番号とその素子の特性を示すパラメータとをファ 20 イル13の中間データに同一形状指定素子群として格納 する。

【0023】また、カレントミラーを構成する2つのト ランジスタは、一方のトランジスタのベース端子とコレ クタ端子とが互いに接続されるとともに、他方のトラン シスタののペース端子に接続されている。この両トラン シスタの接続は、定義「NPN1:C・B,NPN2:B」の「 NFNト ランジスタのコレクタ、ベース端子と他の NPNトランジ スタのペース端子が接続されている場合は近接配置を行 う」に該当する。従って、CPU2はカレントミラーを 構成する両トランシスタを別の1つのグループとし、両 トランジスタの素子番号をファイル13の中間データに 近接配置指定及び同一形状指定素子として格納する。そ して、同一形状素子群の見極め処理31が終了すると、 CPU2は同一形状素子群の見極め追加処理32に移

【0024】次に、同一形状素子群の見極め追加手段と しての同一形状素子群の見極め追加処理32において、 CPU2はファイル14に格納された近接配置指定に該 当する素子の抽出を行う。即ち、CPU2はファイル1 4に格納された近接配置指定を読み出す。この近接配置 指定は予め回路設計段階において複数の回路ブロック又 はマクロ内にそれぞれ存在する素子を近接配置し同一形 状とするように設定しておくものであって、予め設計者 によりその素子が指定されている。従って、その指定さ れた素子は同一形状に形成され、離れて配置されるのを 防止されるようになっている。

【0025】この近接配置指定は、例えば図4に示すよ うに予め定義されている。即ち、定義「S11,S20,S30」 は、「ネットリスト上の素子番号S11,S20,S30 は同一形 - 50 - る。」を意味している。即ち、素子番号「S11 」及び

状とし近接配置を行う」という指定を示している。尚、 素子番号「S11 」,「S20 」,「S30 」は、ネットリス トに記載されているトランジスタ 抵抗、コンデンサ等 をその記載順に対応して付している番号であって、複数 (図4の定義の場合は3つ)の回路ブロックに分かれて 存在している素子を示している。

【0026】そして、CPU2は読み出した近接配置指 定に該当する複数の素子からなる素子群をネットリスト ファイル11に格納されているネットリストから検索す る。そして、ネットリストに該当する素子群が存在する 場合。CPU2はその素子群を1つのグループとしてそ れぞれの素子の素子番号とその素子の特性を示すバラメ 一タとをファイル13の中間データに格納する。そし て、見極め追加処理32を終了すると、CPU2は素子 形状の決定処理33に移る。

【0027】素子形状の決定手段としての素子形状の決 定処理33において、CPU2はファイル15に格納さ れた素子形状指定に基づいて予め形状を同一にする素子 群を中間データから検索する。

【10028】この素子形状指定は、各回路ブロックにお いて素子の形状・サイズを決定した場合、アナログIO 全体の特性からみると各同路プロックに存在する素子に 対して形状・サイズが同一のもの(基準素子)を配置す ると、その配置した後の形状に凹凸が少なくなり、配置 の効率が良くなる。

【0029】即ち、1つの回路ブロックにおけるトラン シスタに対して、他の回路ブロックにおいて2倍の電流 を流すトランジスタがあるとする。このとき、2倍の電 流を流すトランシスタに対しては、1つの回路プロック のトランジスタを2つ並べて配置するとその配置した後 の形状に凹凸が少なくなる。一方、基準となるトランジ スタが1つの回路ブロックにおけるトランジスタの半分 に設定されている場合。1つの回路ブロックのトランジ スタには基準となるトランジスタを2つ、他の回路ブロ ックには基準となるトランシスタを4つ配置するとその 配置した後の形状に凹凸が少なくなり、配置の効率がよ くなる。

【0030】また、1つの回路ブロックにおける抵抗の 値が例えば10KΩであって、他の回路ブロックにおい てその抵抗の値が例えば5 ΚΩとなる場合がある。この 場合、アナログ [ C全体からみると両回路ブロックに含 まれる抵抗は同じ大きさの抵抗を複数並べて配置した方 かその配置効率が良い。即ち、10 K Ω の抵抗は5 K Ωの抵抗の大きさで2つ直列に接続すると、両抵抗を配置 した後の形状の凹凸が少なくなり、配置の効率がよくな

【10031】そして、この素子形状指定は、図5に示す ように定義されている。定義「S11:32」は、「S11 及 びS11 と同一形状とする素子は、2 の素子(BIP) を用い 「S11」と同一形状とする素子はパイポーラトランジスタであって、その特性のために2倍のサイズのパイポーラトランジスタを基本形状とし、その基本形状を複数個並べて配置して「S11」及び「S11」と同一形状とする素子を構成する定義を示している。

【0032】そして、素子形状指定に記述された素子及びその素子と同一形状とする他の素子が中間データに存在する場合、CPU2は各素子の特性を示すパラメータを中間データから読み出す。そして CPU2はその素子がトランシスタ又はコンデンサの場合。その素子の特 10性を示すパラメータを予め設定された基本形状のパラメータで割り、基準となる素子が幾つ必要となるかを演算する

【 0 0 3 3 】 例えば、図5の素子形状指定の内、定義「S11:×2 」の素子番号「S11 」は、図4に示す近接配置指定の内、定義「S11,S20,S30 」の素子番号「S11 」に対応する。従って「素子番号「S20 」、「S30 」は「S11 」と同一形状とする素子に該当する。そして、素子番号「S11 」、「S20 」、「S30 」の特性を示すパラメータをそれぞれ「40」、「40」、「60; とし 基本形 20状の特性を示すパラメータを「20」とする。すると「各素子を構成する基本形状の個数は「40」、「40」、「60」を「20」で割った値、即ち「2」、「2」、「3」となる。

【0034】そして、CPU2は中間データ上のグループ化された素子群(トランシスタ等)に対して配置する基本形状の数をそれぞれ付加して中間データを更新する。このとき 基準となる素子サイズに対してネットリスト上の素子のサイズが整数で割り切れなかった場合がある。例えば素子の特性を示すバラメータが「50」である。例えば素子の特性を示すバラメータが「50」である。の老本形状のバラメータか「20」の場合は「2.5」となり整数とならない。この場合にはその素子に対してその基本形状を使用することができない。従って、CPU2は、その割り切れなかったネットリスト上の素子の素子番号を含むグループをエラーとしてファイル21に格納する。

【0035】一方、素子形状指定に記載された素子が抵抗の場合、CPU2はその素子の抵抗値を上記したトランジスタ等と同様に基本形状の抵抗値で割る。そして、整数で割り切れた場合、CPU2はネットリスト上の素 40子群(抵抗)に対して配置する基本形状の数をそれぞれ付加して中間データを更新する。

【0036】このとき、整数で割り切れなかった場合、CPU2はネットリスト上の素子のサイズを基準サイズで割った残りを1.../2、1.../3等で割る。即ち、抵抗の場合、同一の抵抗値の抵抗を複数並列に接続すると、その抵抗値を並列に接続した数で割った値にすることができる。例えば、 $35 \, \mathrm{K} \, \Omega$ の抵抗を必要とし、基準となる素子サイズが $10 \, \mathrm{K} \, \Omega$ であるとする。このとき  $35 \, \mathrm{K} \, \Omega$ を $10 \, \mathrm{K} \, \Omega$ で割ると、商は $3 \, \mathrm{c} \, \mathrm{c} \, \mathrm{c} \, \mathrm{c}$  の即

ち、10 K  $\Omega$ の抵抗を3 個直列に接続すれば3 0 K  $\Omega$ の抵抗値を得ることができ、必要とする抵抗値に対して5 K  $\Omega$ 不足する。

10

【0.037】次に、CPU2は余りの5 K $\Omega$ を1.72で割る。すると、その値は1.0 K $\Omega$ となり、基準サイズの1.0 K $\Omega$ の抵抗を2つ並列に接続すれば5 K $\Omega$ を得ることができる。従って、3.5 K $\Omega$ の抵抗は1.0 K $\Omega$ の抵抗を5つ使用し、そのうち3つの抵抗を直列に接続し、その3つの抵抗に更に並列接続した2つの抵抗を直列に接続すれば得られる。即ち 複数の基準サイズの抵抗を直列及び並列に接続することにより任意の抵抗値を得ることができることになる。

【0038】しかし、あまりに多くの抵抗を直列及び並列に接続すると、その抵抗の占める面積が増大してアナログICの面積が増大する。従って、ある程度の誤差範囲に入った段階でその抵抗値とするようにして面積の増大を防いている。この誤差範囲をファイル16に格納された許容誤差によって定義している。そして、定義「R=99%」は「抵抗の構成個数算出時の精度は99%とする」を意味している。即ち CPU2は直列及び並列に接続する抵抗の抵抗値を合計した値がネットリスト上の設計された抵抗値の99%以上になったところで演算を終了し、そのときの基本形状となる抵抗の数をネットリスト上の素子群(抵抗)に対してそれぞれ付加して中間データを更新する。

【0039】図6に、以上の処理によりファイル13に格納される中間データの定義を示す。定義「S11(×4)、S20(×1)、S30(×6): NPN:×2 」は 「S11 」、「S20」、「S30」はNPNトランジスタであって、「×2」に定義された基本形状のトランジスタをそれぞれ2個、2個、3個用いて配置する。

【0040】また、「S22(W=40),S21(W=60):PMOS:」は、「S22」、「S21」はPチャネルMOSトランジスタであって、その形状は未定である。この素子番号「S22」、「S21」は、ファイル15の素子形状指定により指定されていない素子であるので、その形状は素子形状の決定処理33で決定されない。

【0041】更に、「S41(3K),S42(1K),S43(100):R:1K」は、「S41」、「S42」、「S43」は抵抗であって、そのサイズは1KΩの抵抗のサイズを複数使用することにより配置する。そして、素子形状の決定処理33が終了すると、CPU2は素子形状の最終決定処理34に移る

【0042】次に、素子形状の最終決定手段としての素子形状の最終決定処理34において、ネットリスト、中間データと、ファイル17に格納された素子対応指定、ファイル18に格納された素子自動生成パラメータ及びファイル19に格納された抵抗幅とに基づいてCPU2は素子の形状を最終的に決定する。即ち CPU2はファイル11のネットリストに記述された素子の素子番号

をファイル13の中間データに格納された素子、即ち近 接配置条件、近接配置指定、素子形状指定により指定さ れた素子番号と比較する。そして、ネットリスト上の素 子番号が指定された素子番号、即ち中間データにない場 合、CPU2はその存在しない素子の特性を示すパラメ ータをネットリストより読み出し、その素子番号と読み 出したパラメータとを素子形状情報としてファイル20 に格納する。

【0043】ネットリスト上の素子番号が指定された素 子番号、即ち中間データにあってその形状が記載されて 10 する。 いる場合、ファイル17に格納された素子対応指定に基 づいてCPU2はその素子番号と形状とにより素子番号 と使用個数及び使用するセル名を素子形状情報としてフ ァイル20に格納する。例えば、図6に示す定義「S11 (×4), S20(×4), S30(×6): NPN:×2 」が該当する。 そして、CPU2は定義「NPN:A2」に対応して図8に 示す2倍のサイズの基本形状を示すセル名の定義「NPN (×2):NPN2 」を読み出す。そして、CPU2は定義「S 11(2),S20(2),S30(3):NPN:NPN2 」を素子形状情報とし てファイル20に格納する。尚、定義のカラコ内の数字 20 は基本形状を使用する個数を示している。

【0044】更に、ネットリスト上の素子番号が指定さ れた素子番号。即ち中間テータにあってその形状が記載 されていない場合、CPU2はその素子の特性を示すバ ラメータに基づいて形状を決定する。このとき、当該す る素子がMOSトランジスタ、BIPトランシスタ及び 容量の場合、CPU2はその定義に記載された素子全て に対してその特性を示すバラメータの最大公約数を計算 し、その最大公約数となるサイズを演算する。

【0045】即ち 素子に対してそのサイスが例えば 「20」、「20」、「30」である場合、そのサイズの最大 **公約数は「10」となる。そして、各素子をサイズ「10」** を基準とし、その基準を「2個」、「2個」、「3個」 使用して配置を行なえばよい。従って、CPU2はその 素子に対する個数をファイル20に素子形状情報として その素子番号とともに格納する。このとき、最大公約数 が整数とならない場合、CPU2は定義された全ての素 子番号をエラー素子としてファイル21に格納する。

【0046】例えばPチャネルMOSトランジスタの場 合、中間データの定義「S22(W=40),S21(W=60):FMOS: 」 はそのサイズが未定である。従って、CPU2はその素 子に対応する最大公約数を計算する。との定義の場合、 最大公約数は「W=20」となり、素子「S22 」はこの「W= 20」の基準となる素子を2個、素子「S21」はこの「W= 20」の基準素子を3個使用してその形状が決定されるこ とになる。そして CPU2はこの基準となる「W=LO」 に対応してファイル17に格納されたセル名を指定する 素子対応指定の定義「PMOS(W=20):PMOS 」を読み出す。 そして、セル名を追加した定義「S22(W=40),S21(W=60): 納する。従って、「S22 」、「S21 」に対してはセル名 「PMOS20」のサイズを基準としてその形状を決定する。 【1)047】また、容量(コンテンサ)に対しては、そ の値により形状を自動に生成することがてきる。そし て、CPU2はトランジスタの場合と同様に容量の最大。 公約数を計算し、その最大公約数となる形状を自動に生 成し、各容量の形状をその自動に生成した形状に基づい て決定する。そして、その容量に使用する個数をその素 子番号とともに素子形状情報としてファイル20に格納

【0048】一方、当該する素子が抵抗の場合、形成す る抵抗の幅を指定することにより形状を自動に生成する ことができる。この抵抗の幅は予め設定され、ファイル 19に格納されている。CPU2は基準となる抵抗の値 に対して他の抵抗がいくつ必要となるかを計算する。そ して、CPU2は必要となる個数とその形状に基づいて 計算した全ての抵抗か占める面積を求め、その面積が最 も小さくなるように基準となる抵抗の形状と使用個数を 計算する。

【0049】即ち、10K豆と30KQの抵抗がある場 合。10KΩの抵抗を基準とした場合。30KΩの抵抗 は10KΩの抵抗を3個直列に接続して得られるので、 その基準となる抵抗が4個必要となる。一方、30ΚΩ の抵抗を基準とした場合。10ΚΩの抵抗は30ΚΩの 抵抗を3個並列に接続するとその値が得られるので、こ の場合も必要となる抵抗の数は4個となる。この場合、 必要となる個数が同じなので、30ΚΩの抵抗による面 積と10ΚΩの抵抗による面積とを比較し、その面積が 小さくなる方の抵抗値を基準とする。

【0050】そして、CPU2は中間データに格納され た抵抗の定義をファイル19の抵抗幅で自動生成するよ うに定義し、その基準となる抵抗値とともに素子形状情 報としてファイル20に格納する。

【0051】この場合、中間データの定義「S41(3K),S4 2(1K),S43(100):R:1k 」は、ファイル19に格納された 抵抗幅「W=5 」とファイル 17 に格納された抵抗の自動 生成の定義「R:?」とにより、定義「S41(3K),S42(1K), S43(100):R:W=5:1k:? 」となる。CPU2は、この定義 を抵抗の素子形状情報としてファイル20に格納する。 【0052】そして、素子形状の最終決定処理34にお いて、ファイル20のネットリストに記述された全ての 素子に対して素子形状の决定を終了すると、CPU2は 素子形状決定処理を終了する。

【0053】このように 本実施例では、予め設定され たネットリストの素子番号により記述された複数種類の 素子に対して。同一形状素子群の見極め処理31におい て、予め設定された近接配置条件に基づいて同一形状と する素子がネットリスト上の素子番号に含まれるか否か を判断する。当該する複数の素子が含まれる場合、これ PMOS:PMOS20 」を素子形状情報としてファイル20に格 50 らの素子番号を1つのカループとし、各グループを中間 データとして記憶する。また、同一形状素子群の見極め 追加処理32において、予め設定された近接配置指定に 基づいて同一形状とする複数の素子の抽出を行なう。そ して
抽出した複数の素子を1つのグループとしてそれ ぞれの素子番号とその素子の特性を示すパラメータとを 中間データに格納するようにした。

13

【0054】そして、素子形状の决定処理33により、 CPU2は予め素子番号に対してそし素子を構成するた めに指定された基本形状が定義された素子形状指定を入 力する。CPU2は、その素子形状指定にある素子番号 10 が中間データに格納された素子番号にあるか否かを判断 する。そして、素子番号を含んだグループがある場合、 CPU2はそのグループ内の各素子の特性を示すパラメ ータを素子形状指定に定義された基本形状の特性を示す パラメータで割る除算を行なう。その除算の結果、割り 切れた場合にはその除算の商を各素子を構成する基本形 状の個数とし、その素子の形状を決定するようにした。 【0055】また。素子形状の決定処理33において、 除算の結果が割り切れない場合であってその素子が抵抗 の場合には割った余りを予め設定された所定の数で割る。20 にしてもよい。 除算を行なう。その除算は、除算の結果の商と基本形状 のバラメータとでその素子の抵抗を形成した場合の抵抗 値が素子の特性を示すパラメータである抵抗値に対して 子め設定された誤差範囲の抵抗値となるまで除算され る。そして、誤差範囲となるまでの商をそれぞれの素子 を構成する基本形状の個数とし、その素子の形状を決定 するようにした。

【0056】更に、素子形状の最終决定処理34におい て、中間データに記憶された各グループないの素子番号 か素子形状指定に指定された素子番号にない場合であっ 30 てその素子がトランジスタ又はコンデンサの場合には同 一形状とする各素子の特性を示すパラメータの最大公約 数を求め、その最大公約数の素子を基準とする。そし て、各素子の特性に対して基準となる素子の個数を求 め、その基準となる素子とその個数とにより各素子の形 状を决定する。一方、素子が抵抗の場合には、各抵抗を それぞれ基準サイズとし、その基準サイズにより各抵抗 の形状を自動生成した場合の総面積を求める。そして、 その総面積か最も小さくなるときの基準サイズで各素子 を形成する個数を計算し、基準サイズと各素子を構成す 40 る個数とにより素子の形状を決定するようにした。

【0057】その結果、ファイル11のネットリストに 記載されたマクロ内の素子の形状を自動に決定すること かでき、この決定した素子の形状を用いて素子のレイア ウトを自動に行うことができる。また、素子の近接配置 条件と素子配置条件とに基づいて素子の配置を行うの で、アナログの制剤を満足した素子配置を行うことがで きる。

【0058】向、本発明は前記実施例の他 以下の態様 で実施するようにしてもよい。

(1)上記実施例では、ファイル15に格納された近接 配置指定に基づいて同一形状素子群の見極め追加処理3 2において第2のグループ合成処理を行うようにした。 が、近接配置指定をせずに同一形状素子群の見極め追加 処理32の処理をなくして実施するようにしてもよい。 【0059】(2)上記実施例の回路設計を行うCAD 装置に組み込んで実施してもよい。図2のレイアウト装 置の構成にグラフィック・ディスプレイを追加すること により、CAD装置の構成と同様になりCAD装置への 組み込みは容易となる。

【0060】また、素子配置を行なう装置に組み込んで 実施してもよい。ファイル20の素子形状情報のフォー マットをその素子配置を行なう装置に入力するフォーマ ットと同一にすれば、効率よく素子配置を行なうことが

【0061】更に、形状決定装置1に磁気ディスク装置 4、磁気テーフ装置7の他 種々の記憶装置、例えば光 磁気ディスク装置、CD-ROM装置等を接続して、プ ログラムデータや各ファイル11~21を記憶するよう

【0062】(3)上記実施例において、各ファイル1 1~19をメモリ3に読み込むことなく実施する。ま た、ファイル20,21をメモリ3に設定することなく 直接磁気ディスク装置4等に書き込むようにしてもよ い。この構成により、メモリ3を小さくすることができ る。

[0063]

【発明の効果】以上詳述したように、本発明によれば、 アナログの制約を満足した素子の形状を自動的に決定す ることができる優れた効果がある。

【図面の簡単な説明】

【図1】本発明の一実施例の形状決定装置の処理フロー 図である。

【図2】一実施例の形状決定装置の構成を示す模式図で

【図3】近接配置の回路条件の一例を示す図である。

【図4】近接配置指定の一例を示す図である。

【図5】素子形状指定の一例を示す図である。

【図6】中間データの一例を示す図である。

【図7】許容誤差の一例を示す図である。

【図8】素子対応指定の一例を示す図である。

【図9】素子自動生成パラメータの一例を示す図であ

【図10】素子形状情報の一例を示す図である。 【符号の説明】

2 CPU

11 ファイル (ネットリスト)

20 ファイル (素子形状情報)

31 同一形状素子群の見極め手段

50 33 素子形状の决定手段

# 34 素子形状の最終決定手段

【図1】

15

## 一変集例の形状決定装置の処理フロー図



# 【図2】

## 一実施側の形状決定装置の構成を示す模式圏



【図4】

### 近後配置指定の一例を示す器

| 定義例           | 意味                                          |
|---------------|---------------------------------------------|
| S11, S20, S30 | ネットリスト上の煮子香号S11, S20, S30は同一形状とし<br>近接配置を行う |

# 【図3】

## 近接配置の回路条件の一例を示す図

| 定套例                | 直味                                                      |  |
|--------------------|---------------------------------------------------------|--|
| NPN1: E, NPN2: E   | NPN T <sub>r</sub> のエミッター箱子同士が接続されている場合は近後配置を行う         |  |
| NPN1: C+8, NPN2: B | NPN T。のコレクター、ベース端子と他のNPN T。のベース端子が<br>接続されている場合は近接配置を行う |  |

# 【図5】

# **畜子形状指定の一側を示す図**

| 定義例       | 重味                                                         |
|-----------|------------------------------------------------------------|
| S11: ×2   | S11及びS11と同一形状とする裏子は×2の裏子(BIP)を見いる。                         |
| S22: W=20 | S22及びS22と同一形状とする素子はW=20の素子 (MOS) を用いる。<br>したついてはネットリストに使う。 |

## 【図6】

### 中間データの一側を示す例

| 定義例                                      | 遺味                                |
|------------------------------------------|-----------------------------------|
| S11 (x4) , S20 (x4) , S30 (x6) : NPN: x2 | NPN TrでX2の形状(サイズ)を使用する            |
| S22 (W=40) , S21 (W=60) : PMOS:          | PMOS T <sub>r</sub> で形装 (サイズ) 甘未定 |
| S41 (3K) , S42 (1K) , S43 (100) : R: 1K  | 抵抗で1K Ωの形状 [サイズ] を使用する            |

## 【図7】

## 許容誤差の一例を示す國

| 定藝術   | 重味                   |
|-------|----------------------|
| R=99% | 派抗の構成個数算出時の精度は99%とする |

# 【図8】

## 煮子対応指定の一側を示す図

| 定義例                  | 意味                                   |  |
|----------------------|--------------------------------------|--|
| NPN (x2) : NPN2      | NPN Trex2の影状(サイズ) 野定ではセル名NPN2を用いる    |  |
| PNP (x2) : PNP2      | PNP Trex2の形状(サイズ)新定ではセル名PNP2を用いる     |  |
| PNOS (N=20) : PNOS20 | PMOS TrでW=20の形状(サイズ)指定ではセル名PNP20を用いる |  |
| R: ?                 | 領抗は自動生成とする                           |  |
| C: ?                 | 容量は自動生成とする                           |  |

# 【図10】

# 素子形状質視の一例を示す因

| 定義例                                      | 意味                              |
|------------------------------------------|---------------------------------|
| S11 (2), S20 (2), S30 (3): NPN: NPN2     | NPN TrでNPN2のセルを () 内の自動配置する     |
| 522 (W=40) , S21 (N=60) ; PHOS; PHOS20   | PMOS T, でPMOS200セルを () 内の個数配置する |
| S41 (34) S42 (14) S43 (100) . 9 W+5 W. 7 | 城前で1KQ(W=5)の形状(サイズ)を自動生成        |

# 【図9】

# 素子自動生成パラメータの一側を示す国

| 素子名 | <b>基味</b>                       |
|-----|---------------------------------|
| 抵抗  | 傷、拡散の種類、施抗長計算式、コンタクト部分の形状を明記する。 |
| 客量  | 種類、及び1ケ当たりの最大値、容量部分の角形骸。        |